# How-to Change Default Clock Settings in Kinetis BSPs

| PRODUCT:         | Freescale MQX™ RTOS                                                                           |
|------------------|-----------------------------------------------------------------------------------------------|
| PRODUCT VERSION: | 3.8.0                                                                                         |
| DESCRIPTION:     | Document describing clock settings changes in the Kinetis BSPs using the ProcessorExpert tool |
| RELEASE DATE:    | December 15 <sup>th</sup> , 2011                                                              |



#### How to Reach Us:

#### Home Page:

www.freescale.com

#### Web Support:

http://www.freescale.com/support

#### **USA/Europe or Locations Not Listed:**

Freescale Semiconductor, Inc.
Technical Information Center, EL516
2100 East Elliot Road
Tempe, Arizona 85284
1-800-521-6274 or +1-480-768-2130
www.freescale.com/support

#### Europe, Middle East, and Africa:

Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) www.freescale.com/support

#### Japan:

Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064 Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com

#### Asia/Pacific:

Freescale Semiconductor China Ltd. Exchange Building 23F No. 118 Jianguo Road Chaoyang District Beijing 100022 China +86 10 5879 8000 support.asia@freescale.com

#### For Literature Requests Only:

Freescale Semiconductor Literature Distribution Center P.O. Box 5405
Denver, Colorado 80217
1-800-441-2447 or +1-303-675-2140
Fax: +1-303-675-2150
LDCForFreescaleSemiconductor@hibbertgroup.com

Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document.

Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals", must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor and its officers, employees, subsidiaries, affliates, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the part.



Freescale™ and the Freescale logo are trademarks of Freescale Semiconductor, Inc. ARC, the ARC logo, ARCangel, ARCform, ARChitect, ARCompact, ARCtangent, BlueForm, CASSEIA, High C/C++, High C++, iCon186, MetaDeveloper, MQX, Precise Solution, Precise/BlazeNet, Precise/EDS, Precise/MFS, Precise/MQX, Precise/MQX Test Suites, Precise/RTCS, RTCS, SeeCode, TotalCore, Turbo186, Turbo86, V8 µ RISC, V8 microRISC, and VAutomation are trademarks of ARC International. High C and MetaWare are registered under ARC International.

All other product or service names are the property of their respective owners.

© Freescale Semiconductor, Inc. 2011. All rights reserved.

Rev. 01 12/2011

#### 1 Introduction

The MQX 3.8 introduces the low power management features on Kinetis platforms. Key building blocks of this solution are the Low Power Manager and Clock Manager modules (referred as LPM and CM in this document). The Clock Manager allows runtime switching between clock configurations statically defined at the BSP level.

In the BSP Clock Manager *bsp\_cm.h* header file, each clock configuration is assigned an index and symbolic name specified. See the BSP\_CLOCK\_CONFIGURATION enum type:

```
typedef enum {
   BSP_CLOCK_CONFIGURATION_0 = 0, /* 96 MHZ PEE */
   BSP_CLOCK_CONFIGURATION_1, /* 12 MHz PEE */
   BSP_CLOCK_CONFIGURATION_2, /* 2 MHz BLPI */
   BSP_CLOCK_CONFIGURATIONS /* Number of available clock configurations */
} BSP_CLOCK_CONFIGURATION;
```

The values of the enum type are used as an input parameter to generic CM functions as well as to the BSP low level CM functions. See the MQX API Reference Manual for the complete description of Clock Manager functions.

```
_cm_set_clock_configuration();
_cm_get_clock_configuration();
_cm_get_clock();
```

There is the low level implementation of the CM functions in the BSP *bsp\_cm.c* file. This implementation contains the following functions:

```
_bsp_initialize_hardware();
_bsp_set_clock_configuration();
_bsp_get_clock_configuration();
_bsp_get_clock();
```

And an optional function used to trim the internal oscillator:

```
__bsp_osc_autotrim();
```

The \_bsp\_initialize\_hardware() function is responsible for basic MCU setting and setting of the Multipurpose Clock Generator (MCG) module. It switches the MCG module from the reset state through the MCG state machine to the default clock configuration indexed as BSP\_CLOCK\_CONFIGURATION\_0. See more information about the MCG Mode State Diagram in the reference manual for selected Kinetis platform.

The \_bsp\_set\_clock\_configuration() function is responsible for runtime switching between defined clock configurations.

The \_bsp\_get\_clock\_configuration() function returns the index of active clock configuration.

The \_bsp\_get\_clock() function returns the clock in Hz of the selected clock source (CM\_CLOCK\_SOURCE) for a given clock configuration (BSP\_CLOCK\_CONFIGURATION). In MQX BSPs this function is implemented as static look up table for a fast access.

When the BSP and the target application uses internal oscillator, the \_bsp\_osc\_autotrim() function has to be implemented to adjust its accuracy. See the MCG Auto TRIM feature described in the "Clock Modules" section in Kinetis reference manual.

Freescale MQX Getting Started

## 2 Default Clock Configuration in MQX BSPs

By default the MQX supports the following target boards with crystals and oscillators:

| Kwikstik    | 8MHz crystal     |
|-------------|------------------|
| TWR-K40X256 | 4MHz crystal     |
| TWR-K53N512 | 50MHz oscillator |
| TWR-K60N512 | 50MHz oscillator |

Three predefined clock configurations were selected as common for all target boards mentioned above:

- 96MHz normal run mode (MGG PEE mode)
- 12MHz normal run mode (MCG PEE mode used also for auto-trimming the internal oscillator)
- 2MHz low power run mode (MCG BLPI mode)

The clock setting configurations were defined in the ProcessorExpert tool. The PE project files are located in the "build\cw10\bsp\_<board>\ProcessorExpert.pe" file. The resulting generated code was put into the CM BSP "source\bsp\<board>\bsp\_cm.\*" source files.

## 3 Using ProcessorExpert to Create Custom Clock Configuration

When creating or cloning the BSP for a custom board it is often necessary to modify the code inside the BSP low level CM functions to accommodate all clock settings requirements.

Generally there are two ways doing it:

- 1. Manually: create or modify the low level functions in the *bsp\_cm.c* and *.h* files.
- 2. Use ProcessorExpert tool to generate the clock setting code.

Manual modification of the code may be a difficult task as the current MQX CM code is already generated by the ProcessorExpert tool (this is the case for MQX 3.8, it may change in future versions).

Note: The current implementation of ProcessorExpert limits the number of available clock configurations to 3.

Steps to use the ProcessorExpert tool to generate clock settings code:

Open CodeWarrior 10.x



Select your Workspace and press OK



 Import the BSP project into workspace by Right-Click the Project Explorer view and select Import



Import the Existing BSP Project into the Workspace





Navigate to the <mqx\_installation\_folder>\mqx\build folder





- Select the BSP project to import and click Finish
- Open the Processor Expert Project Panel if not already opened. Select *Processor Expert / Show Views* menu.
- Expand the CPU component item under the ProcessorExpert.pe project file item:



Right click the CPU and select "Inspector". The CPU Component Inspector opens.





• Unfold the "Internal oscillator" item and set the required parameters.



- Unfold "RTC oscillator" and set
  - Clock frequency [MHz]
  - Capacitor load [pF]



- Unfold "System oscillator" and set
  - o For TWR-K60N512/K53N512
    - Clock source [External reference clock]
    - Clock frequency [MHz] = 50MHz



- o For TWR-K40X256 and KwikStik
  - Clock source[External crystal]
  - Clock frequency [MHz]
    - TWR-K40X256 = 4MHz
    - KwikStik = 8MHz
  - Capacitor load [pF]
  - Oscillator operating mode [High gain / Low power]



Define clock source settings

Kinetis BSPs use 2 clock source settings

PLL Engaged External (PEE)

In PEE mode, the MCG output clock is derived from the PLL output clock, which is controlled by the external reference clock. The FLL is disabled in a low-power state. This setting is used normal run mode as a clock source for BSP\_CLOCK\_CONFIGURATION\_0 and BSP\_CLOCK\_CONFIGURATION\_1.

Bypassed Low Power Internal (BLPI)

In BLPI mode, MCG output clock is derived either from the slow Slow internal reference clock or Fast internal reference clock. Both the FLL and PLL are disabled. This setting is used low power run mode as a clock source for BSP\_CLOCK\_CONFIGURATION\_2.

### Clock source settings 0



#### Clock source settings 1

| Name  |                                | Value             | Details             |
|-------|--------------------------------|-------------------|---------------------|
| ⊡ Clo | ck source setting 1            |                   |                     |
| Ξ     | Internal reference clock       |                   |                     |
|       | MCGIRCLK clock                 | Enabled           |                     |
|       | MCGIRCLK in stop               | Enabled           |                     |
|       | MCGIRCLK source                | Fast              |                     |
|       | MCGIRCLK clock [MHz]           | 2,0               | 2.0 MHz             |
| Ε     | External reference clock       |                   |                     |
|       | OSCERCLK clock                 | Disabled          |                     |
|       | OSCERCLK in stop               | Disabled          |                     |
|       | OSCERCLK clock [MHz]           | 0,0               | 0.0 MHz; System .   |
|       | ERCLK32K clock source          | RTC oscillator    |                     |
|       | ERCLK32K. clock [kHz]          | 0,032768          | 0.032768 MHz        |
| ⊟     | MCG settings                   |                   |                     |
|       | MCG mode                       | BLPI              |                     |
|       | MCG output clock               | Internal clock    |                     |
|       | MCG output [MHz]               | 2,0               | 2.0 MHz             |
|       | MCG external ref. clock source | System oscillator |                     |
|       | MCG external ref. clock [MHz]  | 50,0              | 50.0 MHz            |
|       | Clock monitor                  | Disabled          |                     |
| +     | FLL settings                   |                   |                     |
| ⊟     | PLL settings                   |                   |                     |
|       | PLL module                     | Disabled          |                     |
|       | PLL module in Stop             | Disabled          |                     |
|       | PLL output [MHz]               | 0,0               | 0.0 MHz; PLL is di. |
|       | Reference clock divider        | Auto select       |                     |
|       | PLL reference clock [MHz]      | 2,0               | 2.0 MHz             |
|       | Multiplication factor          | Auto select       |                     |
|       | Loss of lock interrupt         | Disabled          |                     |

#### Define Clock configurations

| Clock configuration 0                 |           | Name |                                             | Value           | Details            |
|---------------------------------------|-----------|------|---------------------------------------------|-----------------|--------------------|
| derived from "Clock Source setting 0" |           | _    | k configurations lock configuration 0       | 3               |                    |
| derived from Clock Source setting o   |           |      | Very low power mode                         | Disabled        |                    |
| BSP CLOCK CONFIGURA                   | ATION 0   |      | VLP mode entry                              | User            |                    |
| Core clock [MHz]                      | 96        |      | VLP exit on interrupt  Clock source setting | Disabled        |                    |
|                                       |           | Ε.   | MCG mode                                    | configuration 0 |                    |
| Bus clock [MHz]                       | 48        |      | MCG output [MHz]                            | 96.0            | 96.0 MHz           |
| External bus clock [MHz]              | 48        |      | MCGIRCLK clock [MHz]                        | 0               | 0.0 MHz; IRCLK is. |
| External bus clock [Miliz]            | 40        |      | OSCERCLK clock [MHz]                        | 0               | 0.0 MHz; System .  |
| Flash clock [MHz]                     | 24        |      | ERCLK32K. dock [kHz]                        | 0.032768        | 0.032768 MHz       |
| PLL/FLL clock selection               | PLL clock | F    | MCGFFCLK [kHz] System clocks                | 24.4140625      | 24.4140625 kHz     |
| PLL/FLL CIOCK SEIECTION               | PLL CIOCK |      | Core clock prescaler                        | Auto select     | 1                  |
| Clock frequency [MHz]                 | 96        |      | Core clock                                  | 96,0            | 96.0 MHz           |
| ' ' '                                 |           |      | Bus clock prescaler                         | Auto select     | 2                  |
| USB clock                             | 48        |      | Bus clock                                   | 48,0            | 48.0 MHz           |
|                                       |           |      | External clock prescaler                    | Auto select     | 2                  |
|                                       |           |      | External bus clock                          | 48,0            | 48.0 MHz           |
|                                       |           |      | Flash clock prescaler                       | Auto select     | 4                  |
|                                       |           |      | Flash clock                                 | 24,0            | 24.0 MHz           |
|                                       |           |      | PLL/FLL clock selection                     | PLL clock       |                    |
|                                       |           |      | Clock frequency [MHz]                       | 96,0            | 96.0 MHz           |
|                                       |           |      | <ul> <li>USB clock settings</li> </ul>      |                 |                    |
|                                       |           |      | USB clock divider                           | Auto select     | 2                  |
|                                       |           |      | USB clock multiply                          | Auto select     | 1                  |
|                                       |           |      | USB clock                                   | 48,0            | 48.0 MHz           |

| Clock configuration 1                 |           | Name Value                                             | Details                                 |
|---------------------------------------|-----------|--------------------------------------------------------|-----------------------------------------|
| · · · · · · · · · · · · · · · · · · · |           | ☐ Clock configurations 3                               |                                         |
| derived from "Clock source setting 0" |           |                                                        |                                         |
| BSP CLOCK CONFIGURA                   | TION 1    | ☐ Clock configuration 1  ☐ Very low power mode Disable | ed.                                     |
| Core clock [MHz]                      | 12        | ☐ Clock source setting config                          | uration 0 If enabled th                 |
|                                       | 10        | MCG mode PEE                                           | fulfilled.                              |
| Bus clock [MHz]                       | 12        | MCG output [MHz] 96,0                                  | 96.0 MHz                                |
| External bus clock [MHz]              | 12        | MCGIRCLK clock [MHz] 0  OSCERCLK clock [MHz] 0         | 0.0 MHz; IRCLK is.<br>0.0 MHz; System . |
|                                       |           | ERCLK32K, dock [kHz] 0.032                             |                                         |
| Flash clock [MHz]                     | 12        | MCGFFCLK [kHz] 24.41                                   |                                         |
| PLL/FLL clock selection               | PLL clock |                                                        | 2.1.1.100201112                         |
| Clock frequency [MHz]                 | 96        | Core clock prescaler Auto s                            | select 8                                |
| Clock frequency [wiriz]               |           | Core clock 12,0                                        | 12.0 MHz                                |
| USB clock                             | 48        | Bus clock prescaler Auto s                             | - Contract                              |
| 002 0.00.1                            |           | Bus clock 12,0                                         | 12.0 MHz                                |
|                                       |           | External clock prescaler Auto s                        | select 8                                |
|                                       |           | External bus clock 12,0                                | 12.0 MHz                                |
|                                       |           | Flash clock prescaler Auto s                           | select 8                                |
|                                       |           | Flash clock 12,0                                       | 12.0 MHz                                |
|                                       |           | □ PLL/FLL clock selection PLL de                       | ock                                     |
|                                       |           | Clock frequency [MHz] 96,0                             | 96.0 MHz                                |
|                                       |           | ─ USB clock settings                                   |                                         |
|                                       |           | USB clock divider Auto s                               | select 2                                |
|                                       |           | USB clock multiply Auto s                              | select 1                                |
|                                       |           | USB clock 48,0                                         | 48.0 MHz                                |

| Clock configuration 2                 |           | Name                                        | Value              | Details            |
|---------------------------------------|-----------|---------------------------------------------|--------------------|--------------------|
|                                       |           | <ul> <li>Clock configurations</li> </ul>    | 3                  |                    |
| derived from "Clock source setting 1" |           | Clock configuration 0                       |                    |                    |
| BSP CLOCK CONFIGURATION 2             |           |                                             |                    |                    |
| Core clock [MHz]                      | 2         | Very low power mode                         | Disabled           |                    |
|                                       |           | ☐ Clock source setting                      | configuration 1    |                    |
| Bus clock [MHz]                       | 2         | MCG mode  MCG output [MHz]                  | BLPI               | 2.000              |
| External bus clock [MHz]              | 2         | MCG output [MHz] MCGIRCLK clock [MHz]       | 2,0                | 2.0 MHz<br>2.0 MHz |
|                                       |           | OSCERCLK clock [MHz]                        | 0                  | 0.0 MHz; System    |
| Flash clock [MHz]                     | 0.5       | ERCLK32K. clock [kHz]                       | 0.032768           | 0.032768 MHz       |
| PLL/FLL clock selection               | PLL clock | MCGFFCLK [kHz]                              | 16.384             | 16.384 kHz         |
|                                       |           |                                             |                    |                    |
| Clock frequency [MHz]                 | 0         | Core clock prescaler                        | Auto select        | 1                  |
| USB clock                             | 0         | Core clock                                  | 2,0                | 2.0 MHz            |
| GOD GIOOK                             |           | Bus clock prescaler                         | Auto select        | 1                  |
|                                       |           | Bus clock                                   | 2,0                | 2.0 MHz            |
|                                       |           | External clock prescaler External bus clock | Auto select        | 1                  |
|                                       |           | External bus clock Flash clock prescaler    | 2,0<br>Auto select | 2.0 MHz            |
|                                       |           | Flash clock prescaler                       | 0,5                | 0.5 MHz            |
|                                       |           | □ PLL/FLL clock selection                   | PLL clock          | U.5 MITZ           |
|                                       |           | Clock frequency [MHz]                       | 0.0                | 0.0 MHz            |
|                                       |           | USB clock settings                          | 0,0                | 0.0 MHZ            |
|                                       |           | USB clock divider                           | Auto select        | 1                  |
|                                       |           | USB clock multiply                          | Auto select        | 1                  |
|                                       |           | USB clock                                   | 0.0                | 0.0 MHz            |

See more detailed description of all CPU component parameters in the ProcessorExpert Help. Right click the component and select "Help on Component"



- When all clock settings is finished and no error is displayed in the Component Inspector. Select menu "Project->Generate Processor Expert Code" to generate code.
- The generated files appear in Generated\_Code directory. The code overloads the default setting
  in bsp\_cm.c. See how the PE\_LDD\_VERSION macro is used for conditional compilation of
  either the default code or the newly generated code.
  - The *Cpu.c* file contains the SetClockConfiguration, GetClockConfiguration, MCGAutotrim methods and set of dependent static functions.
  - The Cpu.h contains defined symbols of CPU frequencies
  - o The *PE\_LDD.c* file contains newly generated array of clock frequencies.

9

- Change the BSP\_CLOCK\_CONFIGURATION enumeration in the bsp\_cm.h file to match your new settings.
- Rebuild the BSP with new clock settings.
- Optionally, you may want to move the generated code back to the bsp\_cm.c and .h files and make it new default clock settings.

**Note**: When not using the CodeWarrior 10.x as the MQX development environment, you can download standalone "Processor Expert Driver Suite" and generate source code as described above. The only difference is files generated in the standalone tool need to be moved to the BSP folder manually or the code has to be merged into the *bsp\_cm.c* and *.h* files directly.